details {
  display: block;
  border: 1px solid $gray-200;
  border-radius: 0.25rem;
  padding: 0.5rem 1rem 0;
  margin: 0.5rem 0;
}

/*
details summary {
  &::marker {
    content: "";
  }
}
*/

summary {
  list-style: none;
  display: inline-block;
  width: calc(100% + 2rem);
  margin: -0.5rem -1rem 0;
  padding: 0.5rem 0.75rem;
}

summary::-webkit-details-marker {
  display: none;
}

summary:hover {
  background: $gray-100;
}

details summary::before {
  display: inline-block;
  content: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='rgba%2829, 45, 53, 0.75%29' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M5 14l6-6-6-6'/%3e%3c/svg%3e");
  transition: transform 0.35s ease;
  transform-origin: center center;
  margin-right: 0.375rem;
}

details[open] > summary::before {
  transform: rotate(90deg);
}

/*
details summary > * {
  display: inline-block;
}
*/

details[open] {
  padding: 0.5rem 1rem;
}

details[open] > summary {
  border-bottom: 1px solid $gray-300;
  margin-bottom: 0.5rem;
}

details h2,
details h3,
details h4 {
  margin: 1rem 0 0.5rem;
}

details p:last-child {
  margin-bottom: 0;
}

details ul,
details ol {
  margin-bottom: 0;
}

details pre {
  margin: 0 0 1rem;
}
